* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  -webkit-tap-highlight-color: transparent;
}

html,
body,
#app {
  height: 100%;
}

body {
  background-color: #f7f8fa;
}

/* 首页背景色 */
body.home-page {
  background-color: #000;
}

a {
  text-decoration: none;
  color: inherit;
}

ul,
li {
  list-style: none;
}
:root {
  /* 字体大小 */
  --font-size-xs: 12px;
  --font-size-sm: 14px;
  --font-size-base: 16px;
  --font-size-lg: 18px;
  --font-size-xl: 20px;
  --font-size-xxl: 22px;

  /* 字体粗细 */
  --font-weight-light: 300;
  --font-weight-normal: 400;
  --font-weight-bold: 600;

  /* 颜色 */
  --color-primary: #fe2c55;
  --color-success: #07c160;
  --color-warning: #ff976a;
  --color-danger: #ee0a24;
  --color-black: #000;
  --color-white: #fff;

  /* 文字颜色 */
  --font-color-base: #222;
  --font-color-gray: #666;
  --font-color-light: #999;
  --font-color-red: #ff0000;

  /* 背景颜色 */
  --bg-color: #f7f8fa;
  --bg-color-light: #fff;
  --bg-color-dark: #000;
  --bg-mask: rgba(0, 0, 0, 0.4);

  /* 边框颜色 */
  --border-color: #e8e8e8;
  --border-color-light: #f0f0f0;

  /* 间距 */
  --spacing-xs: 6px;
  --spacing-sm: 8px;
  --spacing-md: 12px;
  --spacing-lg: 16px;
  --spacing-xl: 24px;

  /* 圆角 */
  --radius-sm: 2px;
  --radius-md: 4px;
  --radius-lg: 8px;
  --radius-xl: 12px;
  --radius-circle: 50%;

  /* 阴影 */
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.1);
  --shadow-md: 0 2px 4px rgba(0, 0, 0, 0.1);
  --shadow-lg: 0 4px 8px rgba(0, 0, 0, 0.1);

  /* 组件相关 */
  --header-height: 44px;
  --tabbar-height: 50px;
  --tab-height: 30px;
  --tab-font-weight: 600;
  --tab-line-color: var(--color-black);
  --tab-active-color: var(--color-black);
}

/* 布局类 */
.flex {
  display: flex;
}

.flex-column {
  display: flex;
  flex-direction: column;
}

.flex-center {
  display: flex;
  align-items: center;
  justify-content: center;
}

.flex-between {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.flex-1 {
  flex: 1;
}

.flex-shrink-0 {
  flex-shrink: 0;
}

/* 定位类 */
.fixed-full {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

.absolute-full {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

/* 文本类 */
.text-ellipsis {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.text-center {
  text-align: center;
}

.text-right {
  text-align: right;
}

/* 滚动类 */
.scroll-y {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.scroll-x {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.no-scrollbar {
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.no-scrollbar::-webkit-scrollbar {
  display: none;
}

/* 遮罩类 */
.mask {
  background-color: var(--bg-mask);
}

/* 边框类 */
.border-top {
  border-top: 1px solid var(--border-color);
}

.border-bottom {
  border-bottom: 1px solid var(--border-color);
}

/* 空状态 */
.empty-container {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-xl) 0;
}

/* 页面容器 */
.page-container {
  min-height: 100vh;
  background-color: var(--bg-color);
}

/* 内容容器 */
.content-container {
  flex: 1;
  overflow: hidden;
}

/* 渐变遮罩 */
.gradient-mask {
  background: linear-gradient(to bottom, transparent 50%, var(--bg-mask));
}
